//入口文件
import Vue from 'vue'
//1.1导入路由的包
import VueRouter from 'vue-router'
//1.2安装路由
Vue.use(VueRouter)

//每次刚进入网站，肯定会调用main.js,在刚调用的时候，先从本地存储中，将购物车中的数据读出来,放到store中
var car =  JSON.parse(localStorage.getItem('car') || '[]')


//注册vuex
import Vuex from 'vuex'
Vue.use(Vuex)
var store = new Vuex.Store({
  state:{//this.$store.sate.***
    car:[], //将购物车中商品的数据，用一个数组存储起来,在car数组中存储一些商品的对象，咱们吗可以暂时将这个商品对象，设计成这个样子{id:商品id,count:购买数量,price:商品标价,selected:表示商品是否被选中false}

  },
    mutations:{
      //this.$store.commit('方法名称','按需传递唯一的参数')
        addToCar(state,goodsinfo){
            //加入购物车，把商品信息保存到store中的car上
            /*
            * 分析：
            * 1、如果购物车中之前就已经有对应的商品了，那么直需要更新数量
            * 2、如果没有，则直接把商品数据，push到car中即可
            * */
            //假设在购物车中，没有找到对应是商品
            var flag = false;
            state.car.some(item => {
                if(item.id == goodsinfo.id){
                    item.count += parseInt(goodsinfo.count);
                    flag = true;
                    return true
                }
            })

            //如果最终循环完毕，得到的flag还是flase，则把商品数据直接push到购物车中
            if(!flag){
                state.car.push(goodsinfo);
            }

            //当更新car之后，把car数组，存储到本地的localStorage中
            localStorage.setItem('car',JSON.stringify(state.car))
        },
        updateGoodsInfo(state,goodsinfo){
            //修改购物车中商品数量值
            state.car.some(item => {
                if(item.id == goodsinfo.id){
                    item.count = parseInt(goodsinfo.count);
                    return true;
                }
            })
            //修改商品的数量，把最新的购物车数据保存到本地存储中
            localStorage.setItem('car',JSON.stringify(state.car))
        },
        removeFromCar(state,id){
            //根据id，从store中的购物车中删除对应的那条商品数据
            state.car.some(item => {
                if(item.id == id){
                    state.car.splice(i,1);
                    return true
                }
            })
            //将删除完毕后，最新的购物车数据，同步到本地存储中
            localStorage.setItem('car',JSON.stringify(state.car))
        },
        getGoodsCountAndAmount(state){
            var o = {
                count:0, //勾选的数量
                amount:0, //勾选的总价
            }

            state.car.forEach(item => {
                if(item.selected){
                    o.count += item.count;
                    o.amount += item.price + item.count;
                }
            })
            return o;
        }
    },
    getters:{
      //this.$store.getters.***
        //相当于计算属性，也相当于filterss
        getAllCount(state){
            var c = 0;
            state.car.forEach(item => {
                c += item.count;
            })
            return c
        },
        getGoodsCount(state){
            var o = {};
                state.car.forEach(item => {
                   o[item.id] = item.count;
            })
            return o
        },
        getGoodsSelected(state){
            var o = {}
            state.car.forEach(item => {
                o[item.id] = item.selected
            })
            return o;
        },
        updateGoodsSelected(state,info){
            state.car.some(item => {
                if(item.id == info.id){
                    item.selected = info.selected;
                }
            })

            //把最新的所有购物车商品的状态保存到store中去
            localStorage.setItem('car',JSON.stringify(state.car));
        },

    },
})




//导入格式化时间的插件
import moment from 'moment'
//定义全局的过滤器
Vue.filter('dateFormat',function (dataStr,pattern="YYYY-MM-DD HH:mm:ss") {
     //此时需要下载moment.js,来帮助处理时间
     return moment(dataStr).format(pattern);
})

//2.1导入Vue-resource
import VueResource from 'vue-resource'
//2.2安装Vue-resource
Vue.use(VueResource)

//设置请求的根路径
Vue.http.options.root = 'http://vue.studyit.io';
//设置全局post表单数据格式的组织形式
Vue.http.options.emulateJSON = true;

//导入App根组件
import app from './App.vue'

//导入MUI样式
import './lib/mui/css/mui.min.css'
import './lib/mui/css/icons-extra.css'

//按需导入mint-ui中的组件,不过按需导入懒加载不好使
/*import { Header,Swipe,SwipeItem,Button,Lazyload } from 'mint-ui';

Vue.component(Header.name, Header);
Vue.component(Swipe.name,Swipe);
Vue.component(SwipeItem.name,SwipeItem);
Vue.component(Button.name,Button);

Vue.use(Lazyload)*/

import MintUI from 'mint-ui'
Vue.use(MintUI)
import 'mint-ui/lib/style.css'

//安装图片预览插件
import VuePreview from 'vue-preview'
Vue.use(VuePreview)

//1.3导入自己的router.js路由模块
import router from './router.js'

var vm = new Vue({
    el:'#app',
    render: c=> c(app),
    router, //1.4挂载路由对象到vm实例上
    store//挂载store状态管理对象
})